<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../plugins/vue.min.js"></script>
    <style>
        #center{
            background-color: #fff;
            border-radius: 5px;
            /* 边框圆角 */
            padding-top: 15px;
            padding-left: 30px;
            padding-bottom: 15px;
            width: 290px;
            height: 160px;
            position: fixed;
            margin:auto;
            left: 0;
            right: 0;
            top: 0;
            bottom:0;
        }
        #overlay{
            background: rgba(0,0, 0, 0.6);
            width: 100%;
            margin: auto;
            position: fixed;
            left: 0;
            right: 0;
            top: 0;
            bottom:0
        }
    </style>
</head>
<body>
    <div id="box">
        <button @click="isShow=true">show</button>

    <!-- 外面的大盒子 -->
    <!-- <div id="overlay" v-show="isShow"  @click="isShow=false">
        <!~~ 内部小盒子 ~~>
        <!~~ 防止冒泡  没有事件源,可以直接写这个指令 ~~>
        <div id="center" @click.stop>
            <div>
                用户名:<input type="text"><br>
                密码:<input type="password"/>
                <div><button>登录</button></div>
            </div>
        </div>
    </div> -->
    <div id="overlay" v-show="isShow"  @click.self="isShow=false">
        <div id="center">
            <div>
                用户名:<input type="text"><br>
                密码:<input type="password"/>
                <div><button>登录</button></div>
            </div>
        </div>
    </div>
    </div>  
   <script>
    let vm = new Vue({
        el:'#box',
        data:{
            isShow:false
        }
    })
   </script>
</body>
</html>